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METHOD AND APPARATUS TO DETERMINE BROADCAST CONTENT 
AND SCHEDULING IN A BROADCAST SYSTEM 

BACKGROUND OF THE INVENTION 

5 Field of the Invention 

The present invention relates generally to broadcast systems and, more 
specifically, the present invention relates to providing content on demand in 
broadcast systems. 

"Back ground Information 

1 o Broadcast systems traditionally transmit data in one direction from a 

server system to a plurality of client systems. Users of the client systems typically 
consume the signals received from the server system as they are broadcast. One 
paradigm in which users are provided with content on demand involves server 
systems that broadcast the same data continuously and/or at staggered intervals. 

1 5 Thus, if a user desires to consume a particular data file on demand, the user "tunes 
in" to one of the repeated broadcasts of the data file. One example of this 
paradigm can be illustrated with present day "pay per view" movies that are 
available from cable or satellite television providers. For instance, cable 
television providers commonly broadcast the same movies repeatedly on multiple 

20 channels at staggered intervals. Users that wish to watch a particular movie "on 
demand" simply tune in to one of the channels on which the desired movie is 
broadcast at the beginning of one of the times that the movie is broadcast. The 
continuous and repeated broadcasts of the same data or programs results in a very 
inefficient use of broadcast bandwidth. Bandwidth used to broadcast the same 
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data repeatedly on multiple channels could otherwise be used to broadcast 
different data. 

Another paradigm for providing content on demand in a broadcast system 
involves a user recording a particular data file and later accessing the data file "on 

5 demand." Continuing with the television broadcast illustration discussed above, 
an example of this paradigm is a user setting up his or her video cassette recorder 
(VCR) to record a desired television program. Later, when the user wishes to 
watch the television program "on demand/' the user simply plays the earlier 
recorded program from his or her VCR. Recently, more advanced digital video 

10 recorders have become available, which record the television broadcasts on 

internal hard drives instead of the video cassette tapes used by traditional VCRs. 
However, use of the digital video recorders is similar to traditional VCRs in that 
the users are required to explicitly set the criteria used (e.g. date, time) to 
determine which broadcasts are recorded on the internal hard drives. 

1 5 Another limitation with present day broadcast systems is that it is difficult 

for most users of the client systems to provide feedback to broadcasters with 
regard to programming. For example, continuing with the television broadcast 
illustration discussed above, many of today's television broadcasters rely upon 
Neilson ratings to determine broadcast programming and/or scheduling. Neilson 

20 ratings are generally based upon only a small sampling of a cross-section of the 
public. Consequently, most television viewers have relatively little or no impact 
on broadcast schedules and/or content. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention is illustrated by way of example and not limitation 
in the accompanying figures. 

Figure 1 A is a block diagram illustrating one embodiment of a broadcast 
system in accordance with the teachings of the present invention. 

Figure IB is a block diagram illustrating another embodiment of a 
broadcast system in accordance with the teachings of the present invention. 

Figure 1C is a block diagram illustrating yet another embodiment of a 
broadcast system in accordance with the teachings of the present invention. 

Figure 2 is a block diagram of one embodiment of a computer system 
representative of a client or a server in accordance with the teachings of the 
present invention. 

Figure 3 is a flow diagram illustrating one embodiment of the flow of 
events in a server and a client when broadcasting meta-data and data files in 
accordance with the teachings of the present invention. 

Figure 4 is a flow diagram illustrating one embodiment of the flow of 
events in a client when processing meta-data broadcast from a server to maintain a 
meta-data table and content rating table in accordance with the teachings of the 
present invention. 

Figure 5 is an illustration of one example of meta-data broadcast by a 
server to describe a in accordance with the teachings of the present invention. 

Figure 6 is an illustration of one example of a meta-data table updated and 
maintained by a client in accordance with the teachings of the present invention. 
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Figure 7 is an illustration of one example of a content rating table updated 
and maintained by a client in accordance with the teachings of the present 
invention. 

Figure 8 is diagram an illustrating one embodiment of data files that are 
5 classified by a user in accordance with the teachings of the present invention. 

Figure 9 is diagram illustrating one embodiment of a meta-data table that 
is updated in response to user classifications in accordance with the teachings of 
the present invention. 

Figure 10 is diagram illustrating one embodiment of a meta-data table that 
10 is updated after a user access in accordance with the teachings of the present 
invention. 

Figure 1 1 is diagram illustrating one embodiment of a content rating table 
that is updated after a user access in accordance with the teachings of the present 
invention. 

15 Figure 12 is diagram illustrating another embodiment of a meta-data table 

that is updated after another user access in accordance with the teachings of the 
present invention. 

Figure 13 is a flow diagram illustrating one embodiment of the flow of 
events in a server and a client when broadcasting meta-data and data files and the 
20 server receiving content ratings from the client(s) in accordance with the teachings 
of the present invention. 
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DETAILED DESCRIPTION 

In one aspect of the present invention, signaling methods and apparatuses 
for providing content on demand in a broadcast system are disclosed. In another 
aspect of the present invention, methods and apparatuses are disclosed for rating 
5 content to be broadcast or to be broadcast potentially from a server are disclosed. 
In yet another aspect of the present invention, methods and apparatuses for 
dynamically determining the broadcast content and/or schedule of a server are 
disclosed. In the following description numerous specific details are set forth in 
order to provide a thorough understanding of the present invention. It will be 

10 apparent, however, to one having ordinary skill in the art that the specific detail 
need not be employed to practice the present invention. In other instances, well- 
known materials or methods have not been described in detail in order to avoid 
obscuring the present invention. 

Figure 1 A is an illustration of one embodiment of a broadcast system in 

15 accordance with the teachings of the present invention. As illustrated in the 
depicted embodiment, a server 103 is configured to broadcast information to a 
plurality of clients 105, 107 and 109. In the embodiment shown in Figure 1A, 
client 105 receives a broadcast from server 103 through a link 115 from a 
broadcast antenna 111. Similarly, client 107 receives a broadcast from server 103 

20 through a link 117 and client 109 receives a broadcast from server 103 through a 
link 119 from broadcast antenna 111. In one embodiment, links 115, 117 and 119 
are uni-directional wireless radio frequency (RF) links from broadcast antenna in 
a format such as for example, but not limited to known amplitude modulation 
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(AM) or frequency modulation (FM) radio signals, television (TV) signals, digital 
video broadcast (DVB) signals or the like, which are broadcast through the 
atmosphere. 

In one embodiment, server 103 is configured to broadcast a plurality of 
5 data files, which may be received by clients 105, 107 and 109. In one 

embodiment, the data files may be any combination of a number of different types 
of files including for example video, audio, graphics, text, multi-media or the like. 
For purposes of explanation, many of the examples provided in this disclosure to 
help describe the present invention assume that the data files to be broadcast by 
10 the server are audio/video files, such as for example movies with moving images 
and sound. However, it will be appreciated that the data files broadcast in 
accordance with the teachings of the present invention are not limited only to 
audio/video files. 

As illustrated in the embodiment shown Figure 1 A, there is a one-way or 
15 uni-directional link between the server 103 and clients 105, 107 and 109. 
However, in another embodiment, it is appreciated that there may also be a 
communications link between server 103 and each client 105, 107 and 109, 
respectively. In particular, Figure IB is an illustration of the broadcast system of 
Figure 1 A with the addition of a "back channel" or communications link between 
20 each client 105, 107 and 109 and server 103. In particular, the embodiment 
illustrated in Figure IB shows links 121, 123 and 125, which may be used by 
clients 105, 107 and 109, respectively, to send information back to server 103. In 
one embodiment, however, links 121, 123 and 125 are not utilized in accordance 
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with the teachings of the present invention. As will be discussed, in another 
embodiment, links 121, 123 and 125 are utilized in accordance with the teachings 
of the present invention. Although links 121, 123 and 125 are illustrated in Figure 
IB as direct links between clients 105, 107 and 109 and server 103, it is 
5 appreciated that clients 105, 107 and 109 may communicate information to server 
103 through indirect links such as for example but not limited to broadcasted 
wireless signals, network communications or the like. 

Figure 1C is an illustration of yet another embodiment of a broadcast 
system in accordance with the teachings of the present invention. As shown, 

10 server 103 is coupled to broadcast information to a plurality of clients 105, 107 
and 109 through a network 113. In one embodiment, network 113 may be any 
type of communications network through which a plurality of different devices 
may communicate such as for example but not limited to the Internet, a wide area 
network (WAN), a local area network (LAN), an intranet, or the like. 

15 In the embodiment illustrated in Figure 1C, client 105 is coupled to 

receive information broadcast from server 103 through link 115. Similarly, client 
107 is coupled to receive information broadcast from server 103 through link 117 
and client 109 coupled to receive information broadcast from server 103 through 
link 119. It is noted that in the embodiment illustrated in Figure 1C, links 115, 

20 117 and 1 19 are shown as uni-directional links from network 1 13 to clients 105, 
107 and 109. In another embodiment, links 1 15, 1 17 and 1 19 are bi-directional 
links, which enable clients 105, 107 and 109 to communication information to 
server 103. 
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Figure 2 is a block diagram illustrating one embodiment of a machine 201 
that may be used for the server 103, or clients 103, 105 or 107 in accordance with 
the teachings of the present invention. In one embodiment, machine 201 is a 
computer or a set top box that includes a processor 203 coupled to a bus 207. In 
one embodiment, memory 205, storage 211, display controller 209, 
communications interface 213, input/output controller 215 and audio controller 
227 are also coupled to bus 207. 

In one embodiment, machine 201 interfaces to external systems through 
communications interface 213. Communications interface 213 may include a 
radio transceiver compatible with AM, FM, TV, digital TV, DVB, wireless 
telephone signals or the like. Communications interface 213 may also include an 
analog modem, Integrated Services Digital Network (ISDN) modem, cable 
modem, Digital Subscriber Line (DSL) modem, a T-l line interface, a T-3 line 
interface, an optical carrier interface (e.g. OC-3), token ring interface, satellite 
transmission interface, a wireless interface or other interfaces for coupling a 
device to other devices. 

In one embodiment, a carrier wave signal 223 is received by 
communications interface 213 to communicate with antenna 111. In one 
embodiment, carrier wave signal 225 is received/transmitted between 
communications interface 213 and network 113. In one embodiment, a 
communications signal 225 may be used to interface machine 201 with another 
computer system, a network hub, router or the like. In one embodiment, carrier 
wave signals 223 and 225 are considered to be machine readable media, which 
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may be transmitted through wires, cables, optical fibers or through the 
atmosphere, or the like. 

In one embodiment, processor 203 may be a conventional microprocessor, 
such as for example but not limited to an Intel x86 or Pentium family 
5 microprocessor, a Motorola family microprocessor, or the like. Memory 205 may 
be a machine readable medium such as dynamic random access memory (DRAM) 
and may include static random access memory (SRAM). Display controller 209 
controls in a conventional manner a display 219, which in one embodiment may 
be a cathode ray tube (CRT), a liquid crystal display (LCD), an active matrix 

10 display, a television monitor or the like. The input/output device 217 coupled to 
input/output controller 215 may be a keyboard, disk drive, printer, scanner and 
other input and output devices, including a television remote, mouse, trackball, 
trackpad, joystick, or the like. In one embodiment, audio controller 227 controls 
in a conventional manner audio output 231, which may include for example audio 

15 speakers, headphones, an audio receiver, amplifier or the like. In one 

embodiment, controller also controls in a conventional manner audio input 229, 
which may include for example a microphone or input(s) from an audio or 
musical device, or the like. 

Storage 21 1 in one embodiment may include machine readable media such 

20 as for example but not limited to a magnetic hard disk, a floppy disk, an optical 
disk, a smart card or another form of storage for data. In one embodiment, storage 
211 may include removable media, read-only media, readable/writable media or 
the like. Some of the data may be written by a direct memory access process into 
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memory 205 during execution of software in computer system 201 . It is 
appreciated that software may reside in storage 211, memory 205 or may be 
transmitted or received via modem or communications interface 213. For the 
purposes of the specification, the term "machine readable medium" shall be taken 
to include any medium that is capable of storing data, information or encoding a 
sequence of instructions for execution by processor 203 to cause processor 203 to 
perform the methodologies of the present invention. The term "machine readable 
medium" shall be taken to include, but is not limited to solid-state memories, 
optical and magnetic disks, carrier wave signals, and the like. 

In one embodiment, a broadcast system, such as for example one similar 
to any of those illustrated in Figures 1A-1C, is configured to have a server 103 
broadcast a plurality of data files to a plurality of clients 105, 107 and 109. As 
will be discussed in greater detail below, each of the plurality of data files is 
described with meta-data in accordance with teachings of one embodiment of the 
present invention. In general, meta-data can be considered as a set of descriptors 
or attribute values that describe content or data files to be broadcast or potentially 
broadcast from server 103. The meta-data of the present invention provides 
information that enables client systems 105, 107 and 109 to reason and make 
informed decisions regarding the content of data files to be broadcast later by 
server 103. As will be discussed, various embodiments of the present invention 
utilize the meta-data for client-side filtering, storage management and other 
personalization techniques as well as determine broadcast schedules and content 
of future server broadcasts. 

- 10- 
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Figure 3 is a flow diagram illustrating the processing that is performed in 
accordance with teachings of one embodiment of the present invention. Figure 3 
illustrates one embodiment of a signaling protocol in which signals are 
transmitted such that client systems can locate and acquire broadcast content. 
5 This includes a pre-broadcast of meta-data by server 103 to client systems 105, 
107 and 109. In particular, process block 303 of Figure 3 shows that the server 
broadcasts the meta-data broadcast schedules to the clients. In one embodiment, 
the meta-data broadcast schedule indicates some point in the future when the 
actual meta-data of the present invention is going to be broadcast by the server. In 

10 one embodiment, the client systems use known ports such as for example those 
used in the program and system information protocol (PSIP), DVB, service 
advertising protocol (SAP) or the like to listen for upcoming service 
announcements from the server. 

In one embodiment, each client 105, 107 and 109 contains a known 

15 scheduling service, which accepts requests to wake up, or be activated, at a 

specific time to receive the information broadcast by the server. This scheduling 
service enables the client to wake up at a specified time and select a specified 
service. For example, in one embodiment, this selection process can be 
accomplished by tuning to a specific frequency, such as for example in an 

20 Advanced Television Systems Committee (ATSC) or a DVB transponder or the 
like. In one embodiment, the selection process or can be based on a set of data, 
such as for example multi-cast Internet protocol (IP) addresses, which define a 
service. 

-11- 
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In one embodiment, a client application registers with the client signaling 
system to receive signals from a specific content provider. The client signaling 
system maintains a table of applications associated with specific content 
providers. In one embodiment, information from the server is broadcast over 

5 known addresses such that each client can use the known address. 

Process block 305 shows that the client receives the meta-data broadcast 
schedule from the server. In one embodiment, client systems 105, 107 and 109 
capture and process this pre-broadcast information in order to determine when to 
wake-up and receive content, where to receive the content and which content to 

10 receive. In one embodiment, when the meta-data broadcast schedule is received 
by the client, the registered application in the client is notified to receive the meta- 
data broadcast schedule. 

In one embodiment, the clients wake-up at the pre-specified time indicated 
in the meta-data broadcast schedule to receive the meta-data from the server. 

1 5 Process block 307 shows that the meta-data is then actually broadcast from the 
server to the clients at the time specified in the meta-data broadcast schedule. 
Process block 309 shows that the client receives the broadcast of meta-data from 
the server. As will be discussed, the meta-data includes descriptions of a plurality 
of data files that will be broadcast or potentially broadcast later by the server 

20 system. 

Process block 3 1 1 shows that the client system then updates a meta-data 
table and a content rating table. In one embodiment, a meta-data table and a 
content rating table are updated and maintained internally or locally by each client 

- 12- 
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system in accordance with the teachings of the present invention. 

In one embodiment, a user of the client system may optionally classify any 
one or more of the plurality of data files that are described by the received meta- 
data. As will be discussed, the meta-data table and content rating table are 

5 updated by the client if there are user classification. This is shown in Figure 3 
with process block 313. 

In one embodiment, the clients wake-up to receive a data file broadcast 
schedule from the server. In one embodiment, the data file broadcast schedule 
indicates a future time in which specific data files, which were described in the 

10 previously broadcast meta-data, will be broadcast by the server. Process block 
315 shows that the data files are then actually broadcast from the server to the 
clients at the time specified in the data file broadcast schedule. Process block 317 
shows that the client receives the broadcast of data file broadcast schedule from 
the server. 

15 In one embodiment, the clients wake-up at the pre-specified time indicated 

in the data file broadcast schedule to receive the data files from the server. 
Process block 319 shows that the data files are then actually broadcast from the 
server to the clients at the time specified in the data file broadcast schedule. 

In one embodiment, process block 321 shows that the client receives the 

20 broadcast of the data files from the server. In one embodiment, process block 323 
shows that client-side filtering according to the present invention is provided the 
client selectively storing data files according to the content rating table. In 
another embodiment, client-side filtering is provided by the client selectively 

-13- 
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waking up to selectively receive data files broadcast from the server according to 
the content rating table. In this embodiment, the client then stores the data files 
that were selectively received by the client according to the content rating table. 

In one embodiment, process block 325 shows that the client then updates 
the meta-data table and content rating table if there are any user accesses of the 
stored data files. For purposes of this disclosure, a user access may include a user 
interacting with, viewing, watching, listening to, reading, consuming, etc., a data 
file. For instance, one example of a user accessing a data file may be the user 
watching a particular movie or listening to a particular song provided by one of 
the stored data files in client. In one embodiment, a user access will result in the 
meta-data table and content rating table on the client being updated locally. 

Figure 4 is a more detailed flow diagram illustrating one embodiment of 
the flow of events in a client when processing meta-data broadcasted from a 
server and updating and maintaining a meta-data table and a content rating table 
in accordance with the teachings of the present invention. In particular, process 
block 403 shows that a meta-data table is updated with attributes and attribute 
values included in the meta-data broadcasted from the server. Process block 405 
shows that the content rating table is then updated with an entry for each one of 
the data files described by the meta-data broadcast from the server. 

In one embodiment, it is assumed that a meta-data table, a content rating 
table and a plurality of data files already exist in the client system. In one 
embodiment, the meta-data table, content rating table and plurality of data files 
may be stored and maintained in the client system in memory 205, storage 21 1 or 

-14- 
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by accessing a local network or the like with machine 201 , as illustrated in the 
embodiment shown in Figure 2. 

To help illustrate the meta-data aspect of the present invention, Figure 5 is 
an example of one embodiment of meta-data 501, which may be broadcast by the 

5 server 103 to the clients 105, 107 and 109. For explanation purposes, it is 
assumed that the data files broadcast by server 103 in this example are 
audio/video files such as for example movies or TV programming. As mentioned 
above, data files may be other types of files such as for example but not limited to 
audio, graphics, text, multi-media or the like. 

10 In the illustrated embodiment, meta-data 501 in Figure 5 shows that four 

movies, or data files, will be broadcast later by server 103. These movies shown 
in this example are "Action Dude," "The Funny Show," "Blast 'Em" and "Hardy 
Har Har Meta-data 501 includes attributes and attribute values that describe 
each one of the movies to be broadcast later by server 103. In the example 

1 5 illustrated, two attributes are provided to describe each movie in meta-data 501 . 
The attributes shown in Figure 5 are "Actor" and "Genre." It is appreciated that 
other embodiment of the present invention may include different attributes as well 
as or attributes values. For instance, a non-exhaustive list of other attributes that 
may be used to describe movies may include "Director," "Year," "Effects," 

20 "Ending," etc. In one embodiment, for example, 40-50 different attributes are 
provided to describe movies in accordance with the teachings of the present 
invention. 

Referring back to the particular example shown in Figure 5, "Action 
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Dude" is an "action" movie featuring actor "Joe Smith." "The Funny Show" is 
"comedy" movie featuring actress "Jane Doe." "Blast 'Em" is an "action" movie 
featuring actor "Jane Doe." "Hardy Har Har" is a "comedy" movie featuring "Joe 
Smith." 

5 To help illustrate the meta-data table aspect of the present invention, 

Figure 6 is an example of one embodiment of meta-data table 601, which is 
updated and maintained locally by each client 105, 107 and 109. In the illustrated 
embodiment, meta-data table 601 in Figure 6 has been populated with the data 
included in meta-data 501, which was broadcasted earlier from server 103. In one 

10 embodiment, meta-data table 601 includes a list of attributes, attribute values and 
corresponding relevance values and believability factors. In particular, meta-data 
table 601 includes attribute values "Joe Smith," "Jane Doe," "action," and 
"comedy." At this time, the relevance values and believability factors for attribute 
values "Joe Smith," "Jane Doe," "action," and "comedy" are all zero in Figure 6. 

15 As will be shown, in one embodiment, the relevance values and believability 
factors of the present invention will be updated and maintained as the user 
interacts with the client system. 

In one embodiment, the relevance values in meta-data table 601 are 
indicators as to how relevant the associated attribute and attribute values are for 

20 predicting a particular user's behavior. For instance, the relevance value indicates 
how likely it is for the user to watch a particular movie because of this particular 
attribute value. In one embodiment, relevance values in meta-data table 601 are 
within a range of values such as for example from -10 to 10. As will be 
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discussed, the relevance value may be increased if for example the user watches a 
particular movie or at least expresses an interest in a particular movie having that 
particular attribute value. Conversely, the relevance value may be decreased if the 
user for example does not watch a particular movie or if the user explicitly 
5 indicates that he or she does not want to watch a particular movie having that 
particular attribute value. 

In one embodiment, the believability factors in meta-data table 601 are 
weighting factors to be applied to specific attribute and attribute value pairs when 
rating or predicting whether a user will actually access a particular data file having 

10 that particular attribute value. In one embodiment, believability factors in meta- 
data table 601 are within a range of values such as for example from -10 to 10. In 
one embodiment, the believability factors may be increased for example when an 
attribute value accurately predicts a data file in which the user is interested. 
Conversely, the believability factors may be decreased when a user is interested in 

1 5 the data file, even though the particular attribute value indicates otherwise. 

In one embodiment, meta-data table 601 entries are constructed from the 
aggregation of all meta-data 501 associated with potential content or data files to 
be broadcast from server 103. In one embodiment, entries in meta-data table 601 
are updated based on explicit user requests. In addition, updates to meta-data 

20 table 601 may also be implicitly based on whether a user accesses specific data 
files having particular attribute values, independent of whether the user explicitly 
classifies a particular movie. 

To help illustrate the content rating table aspect of the present invention, 
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Figure 7 is an example of one embodiment of a content rating table 701, which in 
one embodiment is updated and maintained locally by each client 105, 107 and 
109. In the illustrated embodiment, content rating table 701 in Figure 7 includes a 
list of the data files described in meta-data 501 as well as any additional data files 
5 that are currently stored or cached locally by the client. 

In one embodiment, data files may be stored locally by the client in for 
example memory 205, storage 21 1 or in a locally accessible network by machine 
201 of Figure 2. For purposes of this disclosure, data files being stored locally by 
the client may also be interpreted to include a data file stored "locally" by the 

1 0 client in a known network storage configuration, separate from the server. For 
purposes of this disclosure, the data file being stored or cached locally by the 
client is to be interpreted as the data file being stored for later access, retrieval or 
consumption. In one embodiment, the local cache of the present invention is 
considered to be a first level cache. Thus, the local cache the present invention is 

15 sized accordingly to increase the possibility of a single hit. 

Referring back to the continuing example of data files representing 
audio/video files, a movie is stored locally by the client. After a user watches the 
movie, the storage space occupied by the movie is generally considered to be 
available for storage of another movie to be broadcast sometime later. Thus, it is 

20 appreciated that the local cache of the client system is modeled as the single use 
system, e.g. fire and forget, in accordance with teachings of the present invention. 
In one embodiment, it is assumed that when a user accesses a data file, it is not 
likely that the user will want to access that same data file again. If a user has not 
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watched a particular movie, the storage space occupied by that movie is generally 
considered not to be available for storage of another movie. However, if there is 
no additional storage space available and a higher rated movie is to be broadcast, 
the lower rated unwatched movie is replaced by the higher rated movie in 

5 accordance with the teachings of the present invention. 

Referring back to the embodiment of content rating table 701 shown 
Figure 7, each movie also has an associated rating, a rating type indicator, an in 
cache indicator and a next treatment indicator. In one embodiment, the rating 
indicates a rating value for the associated data file. The rating value in one 

10 embodiment may either be explicitly input by a user or implicitly generated by the 
client system by processing meta-data associated with that particular data file. In 
one embodiment, a relatively high rating value predicts that the particular data file 
may be of interest to the user. Conversely, in one embodiment, a relatively low 
rating value predicts that the particular data file is unlikely to be of interest to the 

15 user. 

In one embodiment, the rating type indicator indicates whether the rating 
value of this particular data file was a result of explicit input from the user or if 
the rating value was implicitly generated by the client system. Thus, in one 
embodiment, the rating type indicator of content rating table 701 may be explicit, 
20 implicit or N/A if the data file or movie has not yet been rated. In one 

embodiment, if a data file has been explicitly classified by a user, the rating values 
of attribute values of the data file are no longer updated implicitly by the client 
system. However, if a data file has not yet been classified or has only been 
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implicitly rated by the client system, the rating of the attribute values of the data 
file may be further updated or adjusted by the client system. 

In one embodiment, the in cache indicator indicates whether that particular 
data file is currently stored or cached locally by the client. In the embodiment 
5 illustrated in Figure 7, the movies "Action Dude," "The Funny Show" and "Blast 
'Em" already exist in the local storage of the client system. Conversely, the 
movie "Hardy Har Har" has not been stored in the local storage of the client 
system in the example illustrated in Figure 7. 

In one embodiment, the next treatment indicator is used to track future 
1 0 actions to be taken for the particular data file. For example, if a movie has already 
been watched by the user, the next treatment indicator would indicate "replace" to 
indicate that the storage space occupied by that particular movie is available for 
storage of another movie. In one embodiment, if the movie has not yet been 
watched by the user, the next treatment indicator would indicate "keep." In one 
1 5 embodiment, if the movie has not been stored locally by the client and if the 
rating value predicts that this particular movie may be of interest to the user, the 
next treatment indicator would indicate "capture." In one of embodiment, if the 
movie has not yet been broadcast by the server and the rating predicts that this 
movie is unlikely to be of interest to the user, the next treatment indicator would 

20 indicate "ignore." 

As was discussed back to Figure 4, process blocks 403 and 405 show that 
the meta-data table and the content rating table are updated according to meta-data 
broadcast from the server. Decision block 407 shows that it is then determined 
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whether there is a user classification of any of the data files. Referring briefly to 
Figure 8, an example is shown where a user classifies some of the movies, as 
described by meta-data 501 . In particular, the user has expressed interest in the 
movie "Action Dude" by indicating that he or she wishes to receive that movie. 
5 In this example, the user has expressed that he or she does not have any interest in 
the movie "The Funny Show" by indicating that he or she refuses that movie. In 
this example, the user has not provided any information or classification regarding 
any of the remaining movies. 

Referring back to Figure 4, if the user has classified any of the data files, 

10 process block 409 shows that the relevance values of the particular attributes of 
the classified data files are updated in meta-data table 601. Process block 411 
shows that the ratings of data files having attribute values with relevance values 
that were adjusted in response to the user classification(s) are also adjusted. In 
one embodiment, if the user has not classified any data files, process blocks 409 

1 5 and 4 1 1 are skipped. 

To illustrate an example of when a user classifies data files, Figure 9 
shows a meta-data table 601 that is updated or adjusted in response to a user 
classification. In the example provided in Figure 8, the user indicated that he or 
she was interested in the movie "Action Dude." Meta-data 501 in Figure 5 shows 

20 that "Action Dude" features actor "Joe Smith" and is an "action" movie. Thus, 
referring to meta-data table 601 in Figure 9, the relevance values for attribute 
values "Joe Smith" and "action" are adjusted to reflect that the user explicitly 
expressed an interest in "Action Dude." In one embodiment, the relevance values 
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are increased to reflect that the user was interested. As will be discussed, in one 
embodiment, the believability factors associated with each attribute value are not 
updated until there is a user access of the data file having that particular attribute 
value. 

5 Continuing with the example of Figure 8, the user indicated that he or she 

was not interested in the movie "The Funny Show." Meta-data 501 in Figure 5 
shows that "The Funny Show" features actress "Jane Doe" and is a "comedy" 
movie. Thus, referring back to meta-data table 601 in Figure 9, the relevance 
values for attribute values "Jane Doe" and "comedy" are adjusted to reflect that 
1 0 the user explicitly expressed that he or she was not interested in "The Funny 

Show." In one embodiment, the relevance values are decremented to reflect that 
the user was not interested. 

Continuing with the example of Figure 8, the user did not provide any 
information regarding the movies "Blast 'Em" and "Hardy Har Har." 
1 5 Accordingly, the relevance values of the attribute values associated with "Blast 
'Em" and "Hardy Har Har" are not updated in meta-data table 601. 

As will be discussed, in one embodiment, updates to the ratings in content 
rating table 701, as described in process block 41 1, are related to the relevance 
values and believability factors of the attribute values listed in meta-data table 
20 601 . A detailed description of the processing that occurs in process block 41 1 
will be discussed below with a discussion of process block 417. 

Referring back to Figure 4, if the user accesses any of the data files, e.g. 
the user watches a movie, as determined in decision block 41 3, process block 415 
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shows that the relevance values and the believability factors of the particular 
attributes of the user accessed data files are updated in meta-data table 601. 
Process block 417 shows that the ratings of data files having attribute values with 
relevance values that were adjusted in response to the user access(es) are also 
5 adjusted. If the user has not accessed any data files, process blocks 415 and 417 
are skipped. 

To illustrate an example of a user accessing data files, assume that the user 
watches the movie "Action Dude." Meta-data 501 in Figure 5 shows that "Action 
Dude" features actor "Joe Smith" and is an "action" movie. In one embodiment, 

10 each time a user accesses or interacts with particular data file, the believability 
factor of the attribute values of that film are adjusted or updated. In one 
embodiment, for attribute values having relevance values greater than zero, the 
believability factor for that attribute value is increased, since that attribute value 
accurately served as a predictor for a data file that the user would access. In one 

1 5 embodiment, for attribute values having relevance values less than zero, the 

believability factor for that attribute value is decreased, since that attribute value 
did not accurately serve as a predictor for a data file that the user would access. 
Therefore, Figure 10 shows a meta-data table 601 that is updated or adjusted in 
response to the user access of "Action Dude." In this example, the believability 

20 factors of "Joe Smith" and "action" are increased since the relevance values for 
these attribute values were greater than zero. 

In one embodiment, the relevance values associated with implicitly rated 
data files are also increased in meta-data table 601 in response to a user access. 
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However, in the example shown in meta-data table 601 of Figure 10, "Action 
Dude" was explicitly classified by the user. In one embodiment, the relevance 
values are not updated in meta-data table 601 in response to a user access of data 
files explicitly classified by the user. 
5 Figure 1 1 shows content rating table 701, which is updated in response to 

the user access of "Action Dude," as described in process block 417. As 
mentioned earlier, content rating table 701 is also updated as described in process 
block 41 1 in accordance with the teachings of the present invention. As shown in 
content rating table 701 of Figure 11, "Action Dude" has a rating value of 1. The 

10 rating type of "Action Dude" is "explicit" because the user explicitly classified 
"Action Dude," as described above in connection with Figure 8. The in cache 
indicator indicates that "Action Dude" is presently locally stored by the client 
system. The next treatment indicator indicates replace because the user has 
already watched "Action Dude." 

15 In one embodiment, the rating values in content rating table 701 are 

determined as follows. Meta-data 501 shows that "Action Dude" has the attribute 
values "Joe Smith" and "action." Meta-data table 601 of Figure 10 shows that 
"Joe Smith" has a relevance value of 1 and a believability factor of 1 . Meta-data 
table 601 of Figure 10 also shows that "action" has a relevance value of 1 and a 

20 believability factor of 1 . In one embodiment, the rating value of a particular data 
file is determined considering the all of the relevance values combined with their 
respective believability factors for all the attribute values of the data file. For 
instance, in one embodiment, the rating value for a data file is equal to the average 
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of all of products of each relevance value and corresponding believability factor 
for the attribute values of the data file. 

To illustrate, referring to "Action Dude" in content rating table 701 of 
Figure 11, the product of the relevance value and believability factor of "Joe 

5 Smith" is 1 * 1, which equals 1. The product of the relevance value and 
believability factor of "action" is 1 * 1, which equals 1. The average of the 
products, 1 and 1, is 1. Therefore, the rating of "Action Dude" in content rating 
table 701 of Figure 11 is 1. 

Similarly, with regard to "Blast 'Em" in content rating table 701, "Blast 

10 'Em" has the attribute values "Jane Doe" and "action." The relevance value and 
believability factors for "Jane Doe" in meta-data table 601 of Figure 10 are -1 and 
0, respectively. Thus, the rating of "Blast 'Em" in content rating table 701 is the 
average of 1 * 0 and 1 * 1, which equals 0.5. The ratings for "The Funny Show" 
and "Hardy Har Har" in content rating table 701 in the example shown in Figure 

15 1 1 are determined in a similar fashion in one embodiment of the present 
invention. 

It is noted that since the user classified the movies "Action Dude" and 
"The Funny Show" above in Figure 8, these movies have an explicit rating type as 
shown in content rating table 701 of Figure 1 1 . Since the user did not classify the 
20 movies "Blast 'Em" and "Hardy Har Har," these movies have an implicit rating in 
content rating table 701. 

It is appreciated that the discussion above provides one example of how 
the rating values in content rating table 701 are determined in accordance with the 
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teachings of the present invention. It is noted that ratings values may be 
determined in other ways in accordance with the teachings of the invention, which 
consider the relevance values and believability factors for each of the attribute 
values of a data file. 

5 In one embodiment, the entry for next treatment in content rating table 701 

is determined in part by the rating and in cache values for the particular data file. 
For example, assume in one embodiment that a rating of greater than zero 
indicates that the user is predicted to have at least some interest in that particular 
movie. Therefore, the movies "Blast 4 Em" and "Hardy Har Har" may be of some 
10 interest to the user. Thus, the next treatment indicates that the movie "Blast 4 Em" 
will be kept in storage and the movie "Hardy Har Har" will be captured when it is 
later broadcast by the server. As mentioned above, the movie "Action Dude" is 
marked for replacement in the next treatment field because it has already been 
watched by the user. 

15 In one embodiment, future interactions by a user with the client system 

results in similar processing as described above. For instance, assume that the 
user now watches the movie "Blast "Em." In this particular example, the user did 
not classify the movie "Blast 'Em" before watching the movie. In one 
embodiment, both of the relevance values and believability factors are updated for 

20 the attribute values of unclassified data files that are accessed, as shown in meta- 
data table 601 of Figure 12. Recall from Figure 5 that the movie "Blast 'Em" 
features "Jane Doe" and is an "action" movie. As shown in Figure 10, the 
relevance value of "Jane Doe" was less than zero, or -1, prior to the user watching 
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"Blast fi Em." Nevertheless, in this example, the user watched "Blast c Em," 
despite the fact that it featured actress "Jane Doe." Accordingly, the believability 
factor of the "Jane Doe" attribute the value is adjusted downward since this 
particular attribute value now appears less likely or relevant when predicting a 
5 user's viewing habits. In one embodiment, since the relevance value is already 
less than zero, the believability factor is not adjusted further downward. 
However, the relevance value and believability factor for the attribute value 
"action" are adjusted upwards since "action" had a relevance value of greater than 
zero prior to the user watching "Blast 'Em " Thus, in this example, the relevance 

10 value is adjusted upwards from 1 to 2 and the believability factor is also adjusted 
upwards from 1 to 2. Therefore, the content rating table 601of Figure 12 now 
predicts that "action" movies are movies that the user is more likely to watch. 

In one embodiment, each time the user interacts with the client system, the 
meta-data table 601 and the content rating table 701 are updated. Updates to be 

1 5 meta-data table 601 and content rating table 7 1 are performed when the user 
accesses data files as well as when the user explicitly classifies data files. It is 
appreciated that the user is not required to classify data files explicitly in order for 
the meta-data table 601 and content rating table 701 to be updated in accordance 
with the teachings of the present invention. As a result, the content rating table 

20 over time will more accurately predict data files in which the user is interested. 

In one embodiment, the data files in which the user is predicted implicitly 
to be most interested as well as the data files in which the user explicitly classified 
an interest will be the data files that are cache locally on the client system. In 
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effect, the movies that the user is most likely to want to watch are automatically 
stored locally, and therefore available "on demand/' in accordance with teachings 
of the present invention without the user having to explicitly request these movies 
in advance or explicitly specify criteria used to identify the movies. 
5 As can be appreciated, by storing the data files locally on each client, 

broadcast bandwidth is utilized more efficiently in accordance with teachings of 
the present invention. Indeed, when a user watches a movie from the local storage 
of the client, no additional broadcast bandwidth is utilized. In addition, it is also 
appreciated that a substantial amount of the processing performed in a system 

10 according to the teachings of the present invention is performed on each of the 
client systems when updating their respective meta-data tables and content rating 
tables. This distributed processing of the present invention enables the presently 
disclosed broadcast system to scale across a very large number of users since the 
incremental cost to the server for each additional client is zero. 

15 In another embodiment, ratings values such as for example those 

generated in the content rating tables maintained and updated by client systems of 
the present invention may be used to determine broadcast content and schedules 
of a server in accordance with teachings of the present invention. For instance, 
assume a broadcast system such as for example the one described above in Figure 

20 IB. As shown in the depicted embodiment, server 103 broadcasts information to 
a plurality of clients 105, 107 and 109. In the depicted embodiment, each client 
105, 107 and 109 also includes a communications link 121, 123 and 125, 
respectively, back to server 103. In one embodiment, the communications links 
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12 1, 123 and 125 are used by server 103 to receive ratings from each client 105, 
107 and 109, respectively. In one embodiment, the ratings received from each 
client are generated in a manner similar to that discussed above. In one 
embodiment, server 103 includes processing that aggregates the ratings received 
5 from each client and is therefore able to identify the most highly rated data files. 
In one embodiment, server 103 then broadcasts the most highly rated data files. 
In one embodiment, the order or time in which server 103 broadcasts the data files 
is determined at least in part by the aggregated ratings received from each of the 
clients. 

10 For instance, Figure 13 is a flow diagram illustrating one embodiment of 

the flow of events in a server and a client of a broadcast system in which 
broadcast content and schedules are determined in response to client ratings in 
accordance with the teachings of the present invention. As shown, process block 
1303 of Figure 13 shows that the server broadcasts meta-data broadcast schedules 

15 to the clients. In one embodiment, the meta-data broadcast schedule indicates 
some point in the future when meta-data is going to be broadcast by the server. 

Process block 1305 shows that the client receives the meta-data broadcast 
schedule from the server. In one embodiment, client systems 105, 107 and 109 
capture and process this pre-broadcast meta-data information in order to 

20 determine when to receive content, where to receive content and which content to 
receive. In one embodiment, the clients wake-up at the pre-specified time 
indicated in the meta-data broadcast schedule to receive the meta-data from the 
server. In one embodiment, the meta-data describe a plurality of data files that 
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will potentially be broadcast later by the server. Process block 1307 shows that 
the meta-data is then actually broadcast from the server to the clients at the time 
specified in the meta-data broadcast schedule. Process block 1309 shows that the 
client receives the broadcast of meta-data from the server. 
5 Process block 1311 shows that in one embodiment the client system then 

updates a meta-data table and a content rating table. Process block 1313 shows 
that in one embodiment, a user of the client system can optionally classify any one 
or more of the plurality of data files that are described by the meta-data. In one 
embodiment, the meta-data table and content rating table are updated by the client 
10 if there are user classifications. In one embodiment, the updates to the meta-data 
table and content rating table described in process blocks 1311 and 1313 are 
performed in a similar manner as described above with respect to for example 
Figures 1-12. 

Process block 1315 shows that the client then sends the ratings of the data 
15 files to the server. In one embodiment, each client in the broadcast network sends 
the ratings for all of the plurality of data files that are described by the meta-data 
broadcast earlier from the server. In one embodiment, each client sends all or part 
of the content rating table maintained on the client system. 

Process block 1317 shows that the server receives the ratings of the data 
20 files from the client(s) in the broadcast system. Process block 1319 shows that the 
server then selects the data files having the highest ratings as determined by the 
client systems. In one embodiment, the server includes processing to aggregate 
all of the ratings received from the clients. In one embodiment, the data files are 
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sorted according to the aggregated ranking. 

Process block 1319 shows that in one embodiment the server then selects 
of the data files in response to the rankings received from all the clients. In one 
embodiment, the data files that are to be broadcast are then determined in 
5 response to the ranking. As a result, one embodiment of a server in accordance 
with the teachings of the present invention broadcasts only the most appropriate 
or relevant data files for the customer base or clients. For instance, in one 
embodiment, only the data files having the highest ranking are broadcast and the 
data files having the lowest ranking are not broadcast. In one embodiment, the 

10 broadcast schedule is also determined in response to be ranking. For instance, in 
one embodiment, the highest ranked data files are broadcast before lower ranked 
data files. In another embodiment, the highest ranked data files are broadcast at a 
time assumed most appropriate to send highly ranked data files. For instance, 
assume an example where Thursday evenings during primetime is the most 

1 5 important time for a broadcaster to have the highest ratings for broadcast. In this 
example, a server in accordance with teachings of the present invention would 
broadcast the highest-ranking data file on Thursday evening during primetime. It 
is appreciated of course the this example was given for explanation purposes only 
and that a server may determine a broadcast schedule in other ways in response to 

20 ratings received from the clients. 

In one embodiment, the data files to broadcast and/or the broadcast 
schedule are determined dynamically by the server in response to the ratings 
received from the client(s) in accordance with teachings of the present invention. 
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Therefore, in one embodiment, broadcast schedules can change over time 
depending on which data files are available from the server and which content or 
data files are accessed and/or classified by the clients. 

Once the data files to be broadcast and the broadcast schedule are 
5 determined by the server, process block 1321 shows that the server then 

broadcasts the data file broadcast schedule to the clients. Process block 1323 
shows that the client then receives the data file broadcast schedule from the 
server. 

In one embodiment, the clients wake-up at the pre-specified time indicated 
10 in the data file broadcast schedule to receive the data files from the server. 

Process block 1325 shows that the data files are then actually broadcast from the 
server to the clients at the time specified in the data file broadcast schedule. 

In one embodiment, process block 1327 shows that the client receives the 
broadcast of the data files from the server. In one embodiment, process block 
15 1329 shows that the client selectively stores data files according to the content 

rating table. In another embodiment, the client selectively wakes up to selectively 
receive data files broadcast from the server according to the content rating table. 
In this embodiment, the client then stores the data files that were selectively 
received by the client according to the content rating table. In one embodiment, 
20 process block 1331 shows that the client then updates the meta-data table and 
content rating table if there any user accesses of the stored data files. 

It is appreciated that the client system in the embodiment described in 
Figure 13 is similar to the client systems described in previous embodiments with 
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the exception of the client system sending ratings back to the server. It is 
appreciated that alternate embodiments of the client system may be utilized in 
accordance with the teachings of the present invention. In one embodiment, the 
client system does not include the client-side filtering of the data files that are 
broadcast from the server. However, the client system does receive the meta-data 
broadcasts from the server, rate the data files and send the ratings back to the 
server in accordance with teachings of present invention. 

In the foregoing detailed description, the method and apparatus of the 
present invention have been described with reference to specific exemplary 
embodiments thereof It will, however, be evident that various modifications and 
changes may be made thereto without departing from the broader spirit and scope 
of the present invention. The present specification and figures are accordingly to 
be regarded as illustrative rather than restrictive. 
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CLAIMS 

What is claimed is: 

1 1. A method, comprising: 

2 broadcasting meta-data to one or more client systems, the meta-data 

3 including descriptions of a plurality of data files; 

4 receiving ratings of each one of the plurality of data files from the one or 

5 more client systems; and 

6 broadcasting a portion of the plurality of data files to the one or more 

7 client systems in response to the ratings received from the one or more client 

8 systems. 

1 2. The method of claim 1 further comprising selecting the portion of the 

2 plurality of data files, which have having higher ratings based on the received 

3 ratings. 

1 3. The method of claim 1 further comprising combining the ratings 

2 received from the client systems, if ratings are received from more than one client 

3 system, to generate an overall ratings list of the plurality of data files. 

1 4. The method of claim 1 further comprising broadcasting a broadcast 

2 schedule of the portion of the plurality of data files prior to broadcasting the 

3 portion of the plurality of data files. 
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1 5. The method of claim 1 further comprising broadcasting a broadcast 

2 schedule of the meta-data prior to broadcasting the meta-data to the one or more 

3 client systems. 

1 6. The method of claim 1 wherein broadcasting the portion of the plurality 



2 of data files to the one or more client systems comprises broadcasting one of the 

3 plurality of data files having a higher rating prior to broadcasting one of the 

4 plurality of data files having a lower rating. 



1 7. An method, comprising: 

2 receiving meta-data broadcast by a server system, the meta-data including 

3 descriptions of a first plurality of data files; 

4 rating in response to a content rating table at least one of the first plurality 

5 of data files described by the meta-data, the content rating table generated 

6 responsive to data files previously accessed; 

7 transmitting the ratings of the at least one of the first plurality of data files 

8 to the server system; 

9 receiving a second plurality of data files broadcast by the server system; 

10 and 

1 1 storing based on the content rating table a portion of the second plurality 

12 of data files broadcast by the server system. 
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1 8. The method of claim 7 further comprising receiving a meta-data 

2 broadcast schedule broadcast by the server system, the client system activated in 

3 response to the meta-data broadcast schedule. 

1 9. The method of claim 7 wherein the first plurality of data files includes 

2 the second plurality of data files. 

1 10. An method, comprising: 

2 receiving meta-data broadcast by a server system, the meta-data including 

3 descriptions of a first plurality of data files; 

4 rating in response to a content rating table at least one of the first plurality 

5 of data files described by the meta-data, the content rating table generated 

6 responsive to data files previously accessed; 

7 transmitting the ratings of the at least one of the first plurality of data files 

8 to the server system; 

9 receiving a broadcast schedule of a second plurality of data files broadcast 

10 by the server system; 

1 1 selectively receiving based on the content rating table a portion of the 

12 second plurality of data files broadcast by the server system; and 

13 storing the portion of the second plurality of data files broadcast by the 

14 server system. 
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1 11. The method of claim 1 0 further comprising receiving a meta-data 

2 broadcast schedule broadcast by the server system, a client system activated in 

3 response to the meta-data broadcast schedule. 

1 12. The method of claim 10 further comprising receiving a broadcast 



2 schedule of the second plurality of data files prior to selectively receiving the 

3 portion of the second plurality of data files. 

1 13. The method of claim 10 wherein the first plurality of data files 

2 includes the second plurality of data files. 

1 14. An apparatus, comprising: 

2 a processor having circuitry to execute instructions; 

3 a communications interface coupled to the processor, the communications 

4 interface coupled broadcast data to one or more client systems, the 

5 communications interface further coupled to receive data from the one or more 

6 client systems; 

7 a storage device coupled to the processor, having sequences of instructions 

8 stored therein, which when executed by the processor cause the processor to 

9 broadcast meta-data to the one or more client systems, the meta-data 

1 0 including descriptions of a plurality of data files; 

1 1 receive ratings of each one of the plurality of data files from the one or 

12 more client systems; and 
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1 3 broadcast a portion of the plurality of data files to the one or more client 

14 systems in response to the ratings received from the one or more client systems. 

1 15. The apparatus of claim 14 wherein the processor is further caused to 

2 select the portion of the plurality of data files, which have having higher ratings 

3 based on the received ratings. 

1 16. The apparatus of claim 14 wherein the processor is further caused to 

2 broadcast a broadcast schedule of the portion of the plurality of data files prior to 

3 broadcasting the portion of the plurality of data files. 

1 17. The apparatus of claim 14 wherein the processor is further caused to 

2 broadcast a broadcast schedule of the meta-data prior to broadcasting the meta- 

3 data to the one or more client systems. 

1 18. An apparatus, comprising: 

2 a processor having circuitry to execute instructions; 

3 a communications interface coupled to the processor, the communications 

4 interface coupled receive data broadcast from a server system, the 

5 communications interface further coupled to transmit data to the server system; 

6 a storage device coupled to the processor, having sequences of instructions 

7 stored therein, which when executed by the processor cause the processor to 



-38- 



042390.P8388 

8 receive meta-data broadcast by a server system, the meta-data including 

9 descriptions of a first plurality of data files; 

1 0 rate in response to a content rating table at least one of the first plurality of 

1 1 data files described by the meta-data, the content rating table generated responsive 

12 to data files previously accessed; 

13 transmit the ratings of the at least one of the first plurality of data files to 

14 the server system; 

15 receive a second plurality of data files broadcast by the server system; and 

16 store based on the content rating table one or more of the second plurality 

1 7 of data files broadcast by the server system. 

1 19. The apparatus of claim 1 8 wherein the processor is farther caused to 

2 receive a meta-data broadcast schedule broadcast by the server system, the client 

3 system activated in response to the meta-data broadcast schedule. 

1 20. The apparatus of claim 1 8 wherein the first plurality of data files 

2 includes the second plurality of data files. 

1 21. An apparatus comprising: 

2 a processor having circuitry to execute instructions; 

3 a communications interface coupled to the processor, the communications 

4 interface coupled receive data broadcast from a server system, the 

5 communications interface further coupled to transmit data to the server system; 
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6 a storage device coupled to the processor, having sequences of instructions 

7 stored therein, which when executed by the processor cause the processor to 

8 receive meta-data broadcast by a server system, the meta-data including 

9 descriptions of a first plurality of data files; 

10 rate in response to a content rating table at least one of the first plurality of 

1 1 data files described by the meta-data, the content rating table generated responsive 

12 to data files previously accessed; 

13 transmit the ratings of the at least one of the first plurality of data files to 

14 the server system; 

1 5 receive a broadcast schedule of a second plurality of data files broadcast 

16 by the server system; 

1 7 selectively receive based on the content rating table a portion of the second 

1 8 plurality of data files broadcast by the server system; and 

1 9 store the portion of the second plurality of data files broadcast by the 

20 server system. 

1 22. The apparatus of claim 21 wherein the processor is further caused to 



2 receive a meta-data broadcast schedule broadcast by the server system, the client 

3 system activated in response to the meta-data broadcast schedule. 

1 23. The apparatus of claim 21 wherein the processor is further caused to 

2 receive a broadcast schedule of the second plurality of data files prior to 

3 selectively receiving the portion of the second plurality of data files. 
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1 24. A machine-readable medium having instructions stored thereon, 

2 which when executed by a processor cause the processor to 

3 broadcast meta-data to one or more client systems, the meta-data including 

4 descriptions of a plurality of data files; 

5 receive ratings of each one of the plurality of data files from the one or 

6 more client systems; and 

7 broadcast a portion of the plurality of data files to the one or more client 

8 systems in response to the ratings received from the one or more client systems. 

1 25. The machine-readable medium of claim 24 wherein the processor is 

2 further caused to select the portion of the plurality of data files, which have 

3 having higher ratings based on the received ratings. 

1 26. A machine-readable medium having instructions stored thereon, 

2 which when executed by a processor cause the processor to 

3 receive meta-data broadcast by a server system, the meta-data including 

4 descriptions of a first plurality of data files; 

5 rate in response to a content rating table at least one of the first plurality of 

6 data files described by the meta-data, the content rating table generated responsive 

7 to data files previously accessed; 

8 transmit the ratings of the at least one of the first plurality of data files to 

9 the server system; 
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1 0 receive a second plurality of data files broadcast by the server system; and 

1 1 store based on the content rating table a portion of the second plurality of 

12 data files broadcast by the server system. 

1 27. The machine-readable medium of claim 26 wherein the process is 

2 further caused to receive a meta-data broadcast schedule broadcast by the server 

3 system, a client system activated in response to the meta-data broadcast schedule. 

1 28. A system, comprising: 

2 a broadcast server; and 

3 one or more client systems coupled to the broadcast server; 

4 wherein the broadcast server is coupled to broadcast meta-data to the one 

5 or more client systems, the meta-data including descriptions of a plurality of data 

6 files; 

7 wherein the one or more client systems are coupled to rate in response to a 

8 content rating table one or more of the plurality of data files described by the 

9 meta-data, the content rating table generated responsive to data files previously 

10 accessed; 

1 1 wherein the one or more client systems are coupled to transmit to the 

12 broadcast server the ratings of the plurality of data files; 

13 wherein the broadcast system is coupled to select a portion of the plurality 

14 of the data files in response to the ratings received from the one or more client 

15 systems; and 
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1 6 wherein the broadcast system is further coupled to broadcast the selected 

1 7 portion of the plurality of data files. 

1 29. The system of claim 28 wherein each one of the one or more client 

2 systems are coupled to selectively store a portion of the selected portion of the 

3 plurality of data files in response to a content rating table associated with each 

4 respective one of the plurality of client systems. 

1 30. The system of claim 28 wherein each one of the one or more client 

2 systems are coupled to selectively receive a portion of the selected portion of the 

3 plurality of data files in response to a content rating table associated with each 

4 respective one of the plurality of client systems. 



-43- 



042390.P8388 



ABSTRACT OF THE DISCLOSURE 

A broadcast system, method and apparatus providing content on demand. 
In one embodiment, the disclosed broadcast system includes a server that 
broadcasts meta-data to a plurality of clients. The meta-data describes a plurality 
of data files that are to be broadcast or potentially broadcast later by the server. 
Each client receives the broadcasted meta-data from the server and updates and 
maintains a local meta-data table and a content rating table. Based on the meta- 
data, previous access habits of the user and optional user classifications, the client 
system selectively receives and/or stores the data files that are later broadcast by 
the server. In one embodiment, the client systems transmit back to the server 
ratings of each one of the data files described by the meta-data based on the user's 
previously accessed data files and optional user classifications. The server then 
determines the data files to be broadcast and the broadcast schedule based on the 
ratings received from the clients. 
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Title 37, Code of Federal Regulations. Section 1.56 
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deafing with the Office, which includes a duty to disclose to the Office all information Known to that individual 
to be material to patentability as defined in this section. The duty to disclosure information exists with respect 
to each pending daim until the claim is cancelled or withdrawn from consideration, or the apr/jcabon becomes 
abandoned. Information material to the patentability of a claim that is cancelled or withdrawn from 
consideration need not be submitted if the information is not material to the patentability of any claim 
remaining under consideration in the application. There is no duty to submit information which ts not material 
to the patentabiUty of any existing claim, The duty to disclosure all information known to be rnatenal to 
patentability is deemed to be satisfied if all information Known to be material to patentability f any daim 
issued in a patent was cited by the Office or submitted to the Office in the manner prescnbed by §§1 -97£Md> 
and i 98 However, no patent will be granted on an application in connection with which fraud on the Office 
was practiced or attempted or the duty of disclosure was violated through bad faith or intentional misconduct 
The Office encourages applicants to carefully examine: 

(1) Prior art cited in search reports of a foreign patent office in a counterpart application, and 

(2) The closest information over which individuals associated with the filing or prosecution of a 
parent application believe any pending claim patentably defines, to make sure that any material information 
contained therein is disclosed to the Office* 

(b) Under this section, information is material to patentability when it is not cumulative to 
information already of record or being made or record in the application, and 

(1 ) it establishes, by itself or in combination with other information, a prima facie case of 
unpatentability of a claim; or 

(2) it refutes, or is inconsistent with, a position the applicant takes in; 

(i) Opposing an argument of unpatentability relied on by the Office, or 

(ii) Asserting an argument of patentability. 

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is 
unpatentable under the preponderance of evidence, burden-of-proof standard, giving each term in the claim 
"its broadest reasonable construction consistent with the specification, and before any consideration is given to 
evidence which may be submitted in an attempt to establish a contrary conclusion of patentability. 

(c) Individuals associated with the filing or prosecution of a patent application within the 
meaning of this section are: 

(1 ) Each inventor named in the application; 

(2) Each attorney or agent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in the preparation or prosecution of the 
application and who is associated with the inventor, with the assignee or with anyone to whom there is an 
oMgation to assign the application. 

{d} Individuals other than the attorney, agent or inventor may comply with this section by 
disclosing information to the attorney, agent, or inventor 
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